| @@ -48,15 +48,25 @@ def shot_detail(request, administrator): | ||
| 48 | 48 | @logit | 
| 49 | 49 | @check_admin | 
| 50 | 50 | def shot_create(request, administrator): | 
| 51 | +    model_id = request.POST.get('model_id', '') | |
| 51 | 52 |      model_name = request.POST.get('model_name', '') | 
| 52 | 53 |      sn = request.POST.get('sn', '') | 
| 53 | -    fittings_type = request.POST.get('fittings_type', 0) | |
| 54 | +    front_cap_status = request.POST.get('front_cap_status', 1) | |
| 55 | +    rear_cap_status = request.POST.get('rear_cap_status', 1) | |
| 56 | +    lens_hood_status = request.POST.get('lens_hood_status', 1) | |
| 57 | +    tripod_ring_status = request.POST.get('tripod_ring_status', 1) | |
| 58 | +    appearance_performance_status = request.POST.get('appearance_performance_status', 1) | |
| 54 | 59 |      tenancy_status = request.POST.get('tenancy_status', 0) | 
| 55 | 60 |  | 
| 56 | 61 | shot = TenancyShotInfo.objects.create( | 
| 62 | + model_id=model_id, | |
| 57 | 63 | model_name=model_name, | 
| 58 | 64 | sn=sn, | 
| 59 | - fittings_type=fittings_type, | |
| 65 | + front_cap_status=front_cap_status, | |
| 66 | + rear_cap_status=rear_cap_status, | |
| 67 | + lens_hood_status=lens_hood_status, | |
| 68 | + tripod_ring_status=tripod_ring_status, | |
| 69 | + appearance_performance_status=appearance_performance_status, | |
| 60 | 70 | tenancy_status=tenancy_status, | 
| 61 | 71 | ) | 
| 62 | 72 |  | 
| @@ -69,15 +79,25 @@ def shot_create(request, administrator): | ||
| 69 | 79 | @check_admin | 
| 70 | 80 | def shot_update(request, administrator): | 
| 71 | 81 |      shot_id = request.POST.get('shot_id', '') | 
| 82 | +    model_id = request.POST.get('model_id', '') | |
| 72 | 83 |      model_name = request.POST.get('model_name', '') | 
| 73 | 84 |      sn = request.POST.get('sn', '') | 
| 74 | -    fittings_type = request.POST.get('fittings_type', 0) | |
| 85 | +    front_cap_status = request.POST.get('front_cap_status', 1) | |
| 86 | +    rear_cap_status = request.POST.get('rear_cap_status', 1) | |
| 87 | +    lens_hood_status = request.POST.get('lens_hood_status', 1) | |
| 88 | +    tripod_ring_status = request.POST.get('tripod_ring_status', 1) | |
| 89 | +    appearance_performance_status = request.POST.get('appearance_performance_status', 1) | |
| 75 | 90 |      tenancy_status = request.POST.get('tenancy_status', 0) | 
| 76 | 91 |  | 
| 77 | 92 |      shot, _ = TenancyShotInfo.objects.update_or_create(shot_id=shot_id, defaults={ | 
| 93 | + 'model_id': model_id, | |
| 78 | 94 | 'model_name': model_name, | 
| 79 | 95 | 'sn': sn, | 
| 80 | - 'fittings_type': fittings_type, | |
| 96 | + 'front_cap_status': front_cap_status, | |
| 97 | + 'rear_cap_status': rear_cap_status, | |
| 98 | + 'lens_hood_status': lens_hood_status, | |
| 99 | + 'tripod_ring_status': tripod_ring_status, | |
| 100 | + 'appearance_performance_status': appearance_performance_status, | |
| 81 | 101 | 'tenancy_status': tenancy_status, | 
| 82 | 102 | }) | 
| 83 | 103 |  | 
| @@ -6,8 +6,8 @@ from tenancy.models import TenancyShotInfo, TenancyShotRequestInfo | ||
| 6 | 6 |  | 
| 7 | 7 |  | 
| 8 | 8 | class TenancyShotInfoAdmin(admin.ModelAdmin): | 
| 9 | -    list_display = ('shot_id', 'model_name', 'sn', 'fittings_type', 'tenancy_status', 'status', 'created_at', 'updated_at') | |
| 10 | -    list_filter = ('fittings_type', 'tenancy_status', 'status') | |
| 9 | +    list_display = ('shot_id', 'model_id', 'model_name', 'sn', 'front_cap_status', 'rear_cap_status', 'lens_hood_status', 'tripod_ring_status', 'appearance_performance_status', 'tenancy_status', 'status', 'created_at', 'updated_at') | |
| 10 | +    list_filter = ('model_name', 'tenancy_status', 'status') | |
| 11 | 11 |  | 
| 12 | 12 |  | 
| 13 | 13 | class TenancyShotRequestInfoAdmin(admin.ModelAdmin): | 
| @@ -0,0 +1,48 @@ | ||
| 1 | +# -*- coding: utf-8 -*- | |
| 2 | +# Generated by Django 3.2.16 on 2022-11-08 15:26 | |
| 3 | + | |
| 4 | +from django.db import migrations, models | |
| 5 | + | |
| 6 | + | |
| 7 | +class Migration(migrations.Migration): | |
| 8 | + | |
| 9 | + dependencies = [ | |
| 10 | +        ('tenancy', '0002_auto_20221105_2323'), | |
| 11 | + ] | |
| 12 | + | |
| 13 | + operations = [ | |
| 14 | + migrations.RemoveField( | |
| 15 | + model_name='tenancyshotinfo', | |
| 16 | + name='fittings_type', | |
| 17 | + ), | |
| 18 | + migrations.AddField( | |
| 19 | + model_name='tenancyshotinfo', | |
| 20 | + name='appearance_performance_status', | |
| 21 | + field=models.BooleanField(default=True, help_text='外观性能状态', verbose_name='appearance_performance_status'), | |
| 22 | + ), | |
| 23 | + migrations.AddField( | |
| 24 | + model_name='tenancyshotinfo', | |
| 25 | + name='front_cap_status', | |
| 26 | + field=models.BooleanField(default=True, help_text='前盖状态', verbose_name='front_cap_status'), | |
| 27 | + ), | |
| 28 | + migrations.AddField( | |
| 29 | + model_name='tenancyshotinfo', | |
| 30 | + name='lens_hood_status', | |
| 31 | + field=models.BooleanField(default=True, help_text='遮光罩状态', verbose_name='lens_hood_status'), | |
| 32 | + ), | |
| 33 | + migrations.AddField( | |
| 34 | + model_name='tenancyshotinfo', | |
| 35 | + name='model_id', | |
| 36 | + field=models.CharField(blank=True, db_index=True, help_text='型号唯一标识', max_length=32, null=True, verbose_name='model_id'), | |
| 37 | + ), | |
| 38 | + migrations.AddField( | |
| 39 | + model_name='tenancyshotinfo', | |
| 40 | + name='rear_cap_status', | |
| 41 | + field=models.BooleanField(default=True, help_text='后盖状态', verbose_name='rear_cap_status'), | |
| 42 | + ), | |
| 43 | + migrations.AddField( | |
| 44 | + model_name='tenancyshotinfo', | |
| 45 | + name='tripod_ring_status', | |
| 46 | + field=models.BooleanField(default=True, help_text='脚架环状态', verbose_name='tripod_ring_status'), | |
| 47 | + ), | |
| 48 | + ] | 
| @@ -25,9 +25,15 @@ class TenancyShotInfo(BaseModelMixin): | ||
| 25 | 25 | ) | 
| 26 | 26 |  | 
| 27 | 27 | shot_id = ShortUUIDField(_(u'shot_id'), max_length=32, blank=True, null=True, help_text=u'镜头唯一标识', db_index=True, unique=True) | 
| 28 | + model_id = models.CharField(_(u'model_id'), max_length=32, blank=True, null=True, help_text=u'型号唯一标识', db_index=True) | |
| 28 | 29 | model_name = models.CharField(_(u'model_name'), max_length=255, blank=True, null=True, help_text=u'型号名称') | 
| 29 | 30 | sn = models.CharField(_(u'sn'), max_length=32, blank=True, null=True, help_text=u'序列号', db_index=True) | 
| 30 | - fittings_type = models.IntegerField(_(u'fittings_type'), choices=FITTINGS_TYPE, default=0, help_text=u'配件类型') | |
| 31 | + # fittings_type = models.IntegerField(_(u'fittings_type'), choices=FITTINGS_TYPE, default=0, help_text=u'配件类型') | |
| 32 | + front_cap_status = models.BooleanField(_(u'front_cap_status'), default=True, help_text=u'前盖状态') | |
| 33 | + rear_cap_status = models.BooleanField(_(u'rear_cap_status'), default=True, help_text=u'后盖状态') | |
| 34 | + lens_hood_status = models.BooleanField(_(u'lens_hood_status'), default=True, help_text=u'遮光罩状态') | |
| 35 | + tripod_ring_status = models.BooleanField(_(u'tripod_ring_status'), default=True, help_text=u'脚架环状态') | |
| 36 | + appearance_performance_status = models.BooleanField(_(u'appearance_performance_status'), default=True, help_text=u'外观性能状态') | |
| 31 | 37 | tenancy_status = models.IntegerField(_(u'tenancy_status'), choices=TENANCY_STATUS, default=0, help_text=u'租借状态') | 
| 32 | 38 |  | 
| 33 | 39 | class Meta: | 
| @@ -41,10 +47,15 @@ class TenancyShotInfo(BaseModelMixin): | ||
| 41 | 47 | def data(self): | 
| 42 | 48 |          return { | 
| 43 | 49 | 'shot_id': self.shot_id, | 
| 50 | + 'model_id': self.model_id, | |
| 44 | 51 | 'model_name': self.model_name, | 
| 45 | 52 | 'sn': self.sn, | 
| 46 | - 'fittings_type': self.fittings_type, | |
| 47 | - 'fittings_type_str': dict(TenancyShotInfo.FITTINGS_TYPE).get(self.fittings_type), | |
| 53 | + # 'fittings_type': self.fittings_type, | |
| 54 | + 'front_cap_status': self.front_cap_status, | |
| 55 | + 'rear_cap_status': self.rear_cap_status, | |
| 56 | + 'lens_hood_status': self.lens_hood_status, | |
| 57 | + 'tripod_ring_status': self.tripod_ring_status, | |
| 58 | + 'appearance_performance_status': self.appearance_performance_status, | |
| 48 | 59 | 'tenancy_status': self.tenancy_status, | 
| 49 | 60 | 'tenancy_status_str': dict(TenancyShotInfo.TENANCY_STATUS).get(self.tenancy_status), | 
| 50 | 61 | 'created_at': tc.local_string(utc_dt=self.created_at), |